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In the claims 

1. (currently amended) A hardware counter comprising: 

a memory array storing a plurality of counter values indexable by an index constructed 
based at least on a number of a plurality of events to which the counter values correspond; and, 

a hardware incrementer to read the counter values from the memory array by values of the 
index, increment the counter values, and write the counter values as incremented back into the 
memory array^ 

wherein the memory array is divided into a plurality of memory banks over which the 

plurality of counter values are stored, each memory bank having a separate instance of the 
hardware incrementer . 

2. (original) The hardware counter of claim 1, wherein the index is constructed as a number 
of bits binarily representing the number of the plurality of events. 

3. (original) The hardware counter of claim 1, wherein the index is constructed further based 
on a number of a plurality of qualifiers to the plurality of events. 

4. (original) The hardware counter of claim 3, wherein the index is constructed as a 
concatenation of a number of bits binarily representing the number of the plurality of events and a 
number of bits binarily representing the number of the plurality of qualifiers, such that each 
counter value corresponds to a unique combination of one of the plurality of events and one of the 
plurality of qualifiers. 

5. (original) The hardware counter of claim 3, wherein the index is constructed as a number 
of bits binarily representing a number of possibly occurring event-and-qualifier combinations, such 
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that each counter value corresponds to a different one of the possibly occurring event-and- 
qualifier combinations, wherein a number of counter values is less than the number of the plurality 
of events multiplied by the number of the plurality of qualifiers. 

6. (original) The hardware counter of claim 5, further comprising index generation hardware 
to generate a value of the index for an input one of the possibly occurring event-and-qualifier 
combinations. 

7. (original) The hardware counter of claim 1 , wherein the hardware incrementer comprises 
a hardware adder that adds an increment value to the counter values, such that results of adding 
the increment value to the counter values is written back into the memory array. 

8. (original) The hardware counter of claim 7, wherein the hardware incrementer further 
comprises a register storing the increment value. 

9. (original) The hardware counter of claim 1, further comprising: 
index generation hardware to generate the index; and, 

hardware to read the counter values from the memory array by the values of the index and 
write the counter values to the memory array. 

10. (cancelled) 

1 1 . (currently amended) The hardware counter of claim [[10]] I, wherein the index globally 
indexes the plurality of counter values over the plurality of memory banks as a whole. 
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12. (currently amended) The hardware counter of claim [[10]] I, wherein each memory bank 
has a separate instance of the index that indexes only those of the plurality of counters stored in 
the memory bank, each memory bank having associated therewith index generation hardware to 
generate the separate instance of the index for the memory bank. 

13. (original) A method comprising: 

generating via hardware a value of an index based on one of a plurality of events and one 
of a plurality of qualifiers to the events , a count value for an occurrence of which the one of the 
plurality of events is to be incremented; 

reading by the value of the index the counter value from a memory array indexed by the 

index; 

incrementing via hardware the counter value; and, 

writing the counter value as incremented back into the memory array^ 

wherein generating via hardware the value of the index comprises generating the index as 

one of: 

a concatenation of a number of bits binarily representing the number of the 

plurality of events and a number of bits binarily representing the number of the plurality of 
qualifiers; and, 

a number of bits binarily representing a number of possibly occurring event-and- 

qualifier combinations, such that each counter value corresponds to a different one of the possibly 
occurring event-and-qualifier combinations . 

14. (cancelled) 

15. (cancelled) 
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16. (original) A system comprising a plurality of nodes, each node having a processor and a 
performance counter operatively coupled to the processor to count occurrences of events, the 
performance counter having a lesser number of hardware incrementers than a number of the 
events of which the performance counter counts the occurrences^ 

wherein the performance counter comprises a plurality of memory banks and a plurality of 

hardware incrementers corresponding to the memory banks, each memory bank storing counter 
values for counting the occurrences of some of the events, each hardware incrementer 
incrementing the counter values of the memory bank to which the hardware incrementer 
corresponds in response to the occurrences of the some of the events to which the counter values 
of the hardware incrementer correspond . 

17. (original) The system of claim 16, wherein the performance counter counts occurrences 
of combinations of events and qualifiers, the performance counter having a lesser number of the 
hardware incrementers than a number of the combinations of the events and the qualifiers of 
which the performance counter counts the occurrences. 

18. (original) The system of claim 16, wherein the performance counter comprises a memory 
array storing counter values for counting the occurrences of the events, and a single hardware 
incrementer to increment the counter values of the memory array in response to the occurrences 
of the events to which the counter values correspond. 

19. (cancelled) 

20. (original) The system of claim 16, wherein each node further comprises memory that is 
local to the processor of the node and remote to the processor of every other of the nodes. 



